<template>
  <div class="box6">
    <div class="title">
      <p>热门电影排行</p>
      <img src="../../images/dataScreen-title.png" alt="" />
    </div>
    <!-- 图形图标的容器 -->
    <div class="charts" ref="charts"></div>
  </div>
</template>

<script setup lang="ts">
import * as echarts from 'echarts'
import { ref, onMounted } from 'vue'
import { ReqRankData } from '@/api/screen'
//获取DOM节点
let charts = ref()
let rankData = ref([])
let arrName = ref([])
let arrValue = ref([])
//组件挂载完毕
onMounted(async () => {
  await getRankData()
  await init()
})
const init = () => {
  //一个容器可以同时展示多种类型的图形图标
  let mychart = echarts.init(charts.value)
  //设置配置项
  mychart.setOption({
    //标题组件
    title: {
      //主标题
      text: '电影排行',
      link: 'http://www.baidu.com',
      //标题的位置
      left: '50%',
      //主标题文字样式
      textStyle: {
        color: 'yellowgreen',
        fontSize: 20,
      },
      //子标题
      subtext: '各大电影排行',
      //子标题的样式
      subtextStyle: {
        color: 'yellowgreen',
        fontSize: 16,
      },
    },
    //x|y轴组件
    xAxis: {
      type: 'category', //图形图标在x轴均匀分布展示
      data: arrName.value,
      axisLabel: {
        color: 'yellowgreen',
        fontSize: 12,
        //文字斜着显示
        // rotate: 45,
        interval: 0,
      },
    },
    yAxis: {
      type: 'value',
    },
    //布局组件
    grid: {
      left: 40,
      bottom: 30,
    },
    //系列:决定显示图形图标是哪一种的
    series: [
      {
        type: 'bar',
        data: arrValue.value,
        //柱状图的:图形上的文本标签，
        label: {
          show: true,
          //文字的位置
          position: 'insideTop',
          //文字颜色
          color: 'white',
        },
        //是否显示背景颜色
        // showBackground: true,
        backgroundStyle: {
          //底部背景的颜色
          color: {
            type: 'linear',
            x: 0,
            y: 0,
            x2: 0,
            y2: 1,
            colorStops: [
              {
                offset: 0,
                color: 'skyblue', // 0% 处的颜色
              },
              {
                offset: 1,
                color: 'green', // 100% 处的颜色
              },
            ],
            global: false, // 缺省为 false
          },
        },
        //柱条的样式
        itemStyle: {
          borderRadius: [10, 10, 0, 0],
          //柱条颜色
          color: function (data: any) {
            //给每一个柱条这是背景颜色
            let arr = [
              '#5475f5',
              '#9feaa5',
              '#3FA7FF',
              '#66E0E3',
              '#FFDC5E',
              '#9fb5ea',
            ]
            return arr[data.dataIndex]
          },
        },
      },
      {
        type: 'line',
        data: arrValue.value,
        smooth: true, //平滑曲线
      },
    ],
    tooltip: {
      backgroundColor: 'rgba(85,215,31,0.9)',
      trigger: 'axis',
      formatter: function (params: any) {
        return params[0].name + ' : ' + params[0].value + ' 元'
      },
    },
  })
}
const getRankData = async () => {
  let result = await ReqRankData()
  if (result.code === 200) {
    rankData.value = result.data
    //取出rankData数组对象中name的数据放入数组中

    for (let i = 0; i < 6; i++) {
      arrName.value.push(rankData.value[i].name)
      arrValue.value.push(rankData.value[i]?.totalPrice)
    }
  }
}
</script>

<style scoped lang="scss">
.box6 {
  width: 100%;
  height: 100%;
  background: url(../../images/dataScreen-main-cb.png) no-repeat;
  background-size: 100% 100%;
  margin: 20px 0px;

  .title {
    margin-left: 5px;

    p {
      color: white;
      font-size: 20px;
    }
  }

  .charts {
    height: calc(100% - 30px);
  }
}
</style>
